#include "common.hpp"

static const char *optString = "r:h?";

static const struct option longOpts[] = {
	{ "help", no_argument, NULL, 'h' },
//	{ "index", required_argument, NULL, 'i' },
	{ "resource", required_argument, NULL, 'r' },
	{ 0,0,0,0 }
};

int main (int argc, char* const argv[]) {
	srand( time(NULL) + getpid() );

//	ipc::semaphore_with_exceptions mutex_llenadora ( my_ftok(MUTEX|LLENADORA),MAX_LLENADORAS );
	ipc::semaphore_with_exceptions mutex_tapadora ( my_ftok(MUTEX|TAPADORA),0);
	ipc::semaphore_with_exceptions mutex_etiquetadora ( my_ftok(MUTEX|ETIQUETADORA),0);

	ipc::messages_queue_with_exceptions llenadoras_salida ( my_ftok(MSG_QUEUE|LLENADORA) );
	ipc::messages_queue_with_exceptions tapadora_salida ( my_ftok(MSG_QUEUE|TAPADORA) );
//	ipc::messages_queue_with_exceptions etiquetadora_salida ( my_ftok(MSG_QUEUE|ETIQUETADORA) );

	int longIndex = 0;
	int option = 0;
	bool ayuda = false;
	size_t procesadas = 0;
	long tapas = 0;

	// Interpretación de parametros.
	while ( (option = getopt_long(argc,argv,optString,longOpts,&longIndex) ) != EOF ) {
		switch (option) {
			case '?':
			case 'h':
			case ':':
				ayuda = true;
				break;
			case 'r':
				tapas = parse<long>(optarg,-1);
			default:
				break;
		}
	}

	if ( ayuda || tapas < 0) {
		std::cerr << "Proceso de control de un brazo con una tapadora de botellas llenas." << std::endl;
		std::cerr << "\tUso: " << argv[0] << " [-h] [-r natural]" << std::endl;
		std::cerr << "\tParametros:" << std::endl;
		std::cerr << "\t\t-h,--help:\tMostrar este mensaje de ayuda." << std::endl;
		std::cerr << "\t\t-r,--resource:\tNúmero de tapas disponibles en la estación." << std::endl;

		return (ayuda) ? 0 : -1;
	}

	try {
		mutex_tapadora.get(PERMITS);
		mutex_etiquetadora.get(PERMITS);

		llenadoras_salida.get(PERMITS);
		tapadora_salida.get(PERMITS);

		sBotella tapada, entrante;
		tapada.tipo = SBOTELLA_TIPO;
		tapada.estado = TAPADA;

		logger << "Estación de tapado: Inicio." << nl;
		procesadas = 0;
		while (tapas > 0) {
			entrante.tipo = CUALQUIERA;
			mutex_tapadora.wait();

				// Comprobar que existen botellas vacias.
				llenadoras_salida.receive(entrante,SBOTELLA_TIPO);

				if ( (entrante.tipo == SBOTELLA_TIPO) && (entrante.tipo == LLENA) ) {
					tapas--;
					logger << "Estación de tapado: Tapando botella " << procesadas+1 << "." << nl;
					// tapar botella.
					usleep ( rand()%1000 + 200 );

					// Enviar botella llena a la siguiente estación.
					tapadora_salida.send(tapada);
					procesadas++;
					logger << "Estación de tapado: Botella tapada " << procesadas << nl;
				} else {
					perror("ERR:");
					error << "Estación de tapado: Botella incorrecta en la maquina." << nl;
				}

			mutex_tapadora.signal();
		} // while (tapas > 0)
		logger << "Estación de tapado: detenida por falta de tapas." << nl;

	} catch (ipc::exception& e) {
		logger << "Estacion de tapado: " << e.what() << "." << nl;
		perror("\tERR");
		exit(-1);
	}
	logger << "Estación de tapado: Fin." << nl;
	return 0;
}
